home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c15 / VLookup.java < prev    next >
Encoding:
Java Source  |  2000-05-25  |  5.0 KB  |  143 lines

  1. //: VLookup.java
  2. //////////////////////////////////////////////////
  3. // Copyright (c) Bruce Eckel, 1998
  4. // Source code file from the book "Thinking in Java"
  5. // All rights reserved EXCEPT as allowed by the
  6. // following statements: You can freely use this file
  7. // for your own work (personal or commercial),
  8. // including modifications and distribution in
  9. // executable form only. Permission is granted to use
  10. // this file in classroom situations, including its
  11. // use in presentation materials, as long as the book
  12. // "Thinking in Java" is cited as the source. 
  13. // Except in classroom situations, you cannot copy
  14. // and distribute this code; instead, the sole
  15. // distribution point is http://www.BruceEckel.com 
  16. // (and official mirror sites) where it is
  17. // freely available. You cannot remove this
  18. // copyright and notice. You cannot distribute
  19. // modified versions of the source code in this
  20. // package. You cannot use this file in printed
  21. // media without the express permission of the
  22. // author. Bruce Eckel makes no representation about
  23. // the suitability of this software for any purpose.
  24. // It is provided "as is" without express or implied
  25. // warranty of any kind, including any implied
  26. // warranty of merchantability, fitness for a
  27. // particular purpose or non-infringement. The entire
  28. // risk as to the quality and performance of the
  29. // software is with you. Bruce Eckel and the
  30. // publisher shall not be liable for any damages
  31. // suffered by you or any third party as a result of
  32. // using or distributing software. In no event will
  33. // Bruce Eckel or the publisher be liable for any
  34. // lost revenue, profit, or data, or for direct,
  35. // indirect, special, consequential, incidental, or
  36. // punitive damages, however caused and regardless of
  37. // the theory of liability, arising out of the use of
  38. // or inability to use software, even if Bruce Eckel
  39. // and the publisher have been advised of the
  40. // possibility of such damages. Should the software
  41. // prove defective, you assume the cost of all
  42. // necessary servicing, repair, or correction. If you
  43. // think you've found an error, please email all
  44. // modified files with clearly commented changes to:
  45. // Bruce@EckelObjects.com. (Please use the same
  46. // address for non-code errors found in the book.)
  47. /////////////////////////////////////////////////
  48.  
  49. // GUI version of Lookup.java
  50. import java.awt.*;
  51. import java.awt.event.*;
  52. import java.applet.*;
  53. import java.sql.*;
  54.  
  55. public class VLookup extends Applet {
  56.   String dbUrl = "jdbc:odbc:people";
  57.   String user = "";
  58.   String password = "";
  59.   Statement s;
  60.   TextField searchFor = new TextField(20);
  61.   Label completion = 
  62.     new Label("                        ");
  63.   TextArea results = new TextArea(40, 20);
  64.   public void init() {
  65.     searchFor.addTextListener(new SearchForL());
  66.     Panel p = new Panel();
  67.     p.add(new Label("Last name to search for:"));
  68.     p.add(searchFor);
  69.     p.add(completion);
  70.     setLayout(new BorderLayout());
  71.     add(p, BorderLayout.NORTH);
  72.     add(results, BorderLayout.CENTER);
  73.     try {
  74.       // Load the driver (registers itself)
  75.       Class.forName(
  76.         "sun.jdbc.odbc.JdbcOdbcDriver");
  77.       Connection c = DriverManager.getConnection(
  78.         dbUrl, user, password);
  79.       s = c.createStatement();
  80.     } catch(Exception e) {
  81.       results.setText(e.getMessage());
  82.     }
  83.   }
  84.   class SearchForL implements TextListener {
  85.     public void textValueChanged(TextEvent te) {
  86.       ResultSet r;
  87.       if(searchFor.getText().length() == 0) {
  88.         completion.setText("");
  89.         results.setText("");
  90.         return;
  91.       }
  92.       try {
  93.         // Name completion:
  94.         r = s.executeQuery(
  95.           "SELECT LAST FROM people.csv people " +
  96.           "WHERE (LAST Like '" +
  97.           searchFor.getText()  + 
  98.           "%') ORDER BY LAST");
  99.         if(r.next()) 
  100.           completion.setText(
  101.             r.getString("last"));
  102.         r = s.executeQuery(
  103.           "SELECT FIRST, LAST, EMAIL " +
  104.           "FROM people.csv people " +
  105.           "WHERE (LAST='" + 
  106.           completion.getText() +
  107.           "') AND (EMAIL Is Not Null) " +
  108.           "ORDER BY FIRST");
  109.       } catch(Exception e) {
  110.         results.setText(
  111.           searchFor.getText() + "\n");
  112.         results.append(e.getMessage());
  113.         return; 
  114.       }
  115.       results.setText("");
  116.       try {
  117.         while(r.next()) {
  118.           results.append(
  119.             r.getString("Last") + ", " 
  120.             + r.getString("fIRST") + 
  121.             ": " + r.getString("EMAIL") + "\n");
  122.         }
  123.       } catch(Exception e) {
  124.         results.setText(e.getMessage());
  125.       }
  126.     }
  127.   }
  128.   public static void main(String[] args) {
  129.     VLookup applet = new VLookup();
  130.     Frame aFrame = new Frame("Email lookup");
  131.     aFrame.addWindowListener(
  132.       new WindowAdapter() {
  133.         public void windowClosing(WindowEvent e) {
  134.           System.exit(0);
  135.         }
  136.       });
  137.     aFrame.add(applet, BorderLayout.CENTER);
  138.     aFrame.setSize(500,200);
  139.     applet.init();
  140.     applet.start();
  141.     aFrame.setVisible(true);
  142.   }
  143. } ///:~